summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorliamwhite <liamwhite@users.noreply.github.com>2023-12-02 15:28:30 +0100
committerGitHub <noreply@github.com>2023-12-02 15:28:30 +0100
commit7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb (patch)
tree1b4f2582bbf3fb4da0ef3fc366c501630c78e120
parentMerge pull request #12256 from GPUCode/fxaa (diff)
parenthost_memory: move MAP_ALIGNED_SUPER attempt after 448d4815dece (diff)
downloadyuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.tar
yuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.tar.gz
yuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.tar.bz2
yuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.tar.lz
yuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.tar.xz
yuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.tar.zst
yuzu-7fb6fbcd87729ec40e4c9a2ddf6493156e3d22bb.zip
-rw-r--r--src/common/host_memory.cpp28
1 files changed, 15 insertions, 13 deletions
diff --git a/src/common/host_memory.cpp b/src/common/host_memory.cpp
index 3a9ea6eb4..4bfc64f2d 100644
--- a/src/common/host_memory.cpp
+++ b/src/common/host_memory.cpp
@@ -25,6 +25,10 @@
#include <unistd.h>
#include "common/scope_exit.h"
+#ifndef MAP_NORESERVE
+#define MAP_NORESERVE 0
+#endif
+
#endif // ^^^ Linux ^^^
#include <mutex>
@@ -404,6 +408,16 @@ static void* ChooseVirtualBase(size_t virtual_size) {
#else
static void* ChooseVirtualBase(size_t virtual_size) {
+#if defined(__FreeBSD__)
+ void* virtual_base =
+ mmap(nullptr, virtual_size, PROT_READ | PROT_WRITE,
+ MAP_PRIVATE | MAP_ANONYMOUS | MAP_NORESERVE | MAP_ALIGNED_SUPER, -1, 0);
+
+ if (virtual_base != MAP_FAILED) {
+ return virtual_base;
+ }
+#endif
+
return mmap(nullptr, virtual_size, PROT_READ | PROT_WRITE,
MAP_PRIVATE | MAP_ANONYMOUS | MAP_NORESERVE, -1, 0);
}
@@ -459,24 +473,12 @@ public:
}
// Virtual memory initialization
-#if defined(__FreeBSD__)
- virtual_base =
- static_cast<u8*>(mmap(nullptr, virtual_size, PROT_NONE,
- MAP_PRIVATE | MAP_ANONYMOUS | MAP_ALIGNED_SUPER, -1, 0));
- if (virtual_base == MAP_FAILED) {
- virtual_base = static_cast<u8*>(
- mmap(nullptr, virtual_size, PROT_NONE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0));
- if (virtual_base == MAP_FAILED) {
- LOG_CRITICAL(HW_Memory, "mmap failed: {}", strerror(errno));
- throw std::bad_alloc{};
- }
- }
-#else
virtual_base = virtual_map_base = static_cast<u8*>(ChooseVirtualBase(virtual_size));
if (virtual_base == MAP_FAILED) {
LOG_CRITICAL(HW_Memory, "mmap failed: {}", strerror(errno));
throw std::bad_alloc{};
}
+#if defined(__linux__)
madvise(virtual_base, virtual_size, MADV_HUGEPAGE);
#endif